**Module Design Document**

**For**

**ExcpnHndlg**

**04-Apr-2018**

**Prepared By:**

**Shruthi Raghavan,**

**Nexteer Automotive,**

**Saginaw, MI, USAChange History**

|  |  |  |  |
| --- | --- | --- | --- |
| **Description** | **Author** | **Version** | **Date** |
| Initial Version | Avinash James | 1.0 | 05-Apr-2016 |
| Updated the #define for ECC single bit code flash fault | Avinash James | 2.0 | 18-Apr-2016 |
| Updated for v3.2.0 of the FDD | Selva Sengottaiyan | 3.0 | 24-June-2016 |
| Updated for v4.0.0 of the FDD | Avinash James | 4.0 | 17-Aug-2016 |
| Updated to remove constants that were used for parameter byte for CVM startup tests because this test is removed from CM101A | Shruthi Raghavan | 5.0 | 18-May-2017 |
| Added constants for the handling of code flash register write MCAL failure. | Shruthi Raghavan | 6.0 | 25-May-2017 |
| Removed the ProcEcmRst Function | Avinash James | 7.0 | 25-Jul-2017 |
| Added local constants | Avinash James | 8.0 | 21-Sep-2017 |
| Added handler for DTS single bit ECC error | Avinash James | 9.0 | 04-Apr-2018 |

Table of Contents[1 Introduction 7](#_Toc488748423)

[1.1 Purpose 7](#_Toc488748424)

[2 ExcpnHndlg & High-Level Description 8](#_Toc488748425)

[3 Design details of software module 9](#_Toc488748426)

[3.1 Graphical representation of ExcpnHndlg 9](#_Toc488748427)

[3.2 Data Flow Diagram 9](#_Toc488748428)

[3.2.1 Component level DFD 9](#_Toc488748429)

[3.2.2 Function level DFD 9](#_Toc488748430)

[4 Constant Data Dictionary 10](#_Toc488748431)

[4.1 Program (fixed) Constants 10](#_Toc488748432)

[4.1.1 Embedded Constants 10](#_Toc488748433)

[5 Software Component Implementation 14](#_Toc488748434)

[5.1 Sub-Module Functions 14](#_Toc488748435)

[5.1.1 Init: ExcpnHndlgInit1 14](#_Toc488748436)

[5.1.1.1 Design Rationale 14](#_Toc488748437)

[5.1.1.2 Module Outputs 14](#_Toc488748438)

[5.1.2 Init: ExcpnHndlgInit2 14](#_Toc488748439)

[5.1.2.1 Design Rationale 14](#_Toc488748440)

[5.1.2.2 Module Outputs 14](#_Toc488748441)

[5.1.3 Per: ExcpnHndlgPer1 14](#_Toc488748442)

[5.1.3.1 Design Rationale 14](#_Toc488748443)

[5.1.3.2 Store Module Inputs to Local copies 14](#_Toc488748444)

[5.1.3.3 (Processing of function)……… 14](#_Toc488748445)

[5.1.3.4 Store Local copy of outputs into Module Outputs 14](#_Toc488748446)

[5.2 Server Runables 14](#_Toc488748447)

[5.2.1 ChkForStrtUpTest 14](#_Toc488748448)

[5.2.1.1 Design Rationale 14](#_Toc488748449)

[5.2.1.2 (Processing of function)……… 14](#_Toc488748450)

[5.2.2 FeNmiClkMonr0RtLowrLimFlt 15](#_Toc488748451)

[5.2.2.1 Design Rationale 15](#_Toc488748452)

[5.2.2.2 (Processing of function)……… 15](#_Toc488748453)

[5.2.3 FeNmiClkMonr0RtUpprLimFlt 15](#_Toc488748454)

[5.2.3.1 Design Rationale 15](#_Toc488748455)

[5.2.3.2 (Processing of function)……… 15](#_Toc488748456)

[5.2.4 FeNmiClkMonr1RtLowrLimFlt 15](#_Toc488748457)

[5.2.4.1 Design Rationale 15](#_Toc488748458)

[5.2.4.2 (Processing of function)……… 15](#_Toc488748459)

[5.2.5 FeNmiClkMonr1RtUpprLimFlt 15](#_Toc488748460)

[5.2.5.1 Design Rationale 15](#_Toc488748461)

[5.2.5.2 (Processing of function)……… 15](#_Toc488748462)

[5.2.6 FeNmiClkMonr2RtLowrLimFlt 15](#_Toc488748463)

[5.2.6.1 Design Rationale 15](#_Toc488748464)

[5.2.6.2 (Processing of function)……… 15](#_Toc488748465)

[5.2.7 FeNmiClkMonr2RtUpprLimFlt 15](#_Toc488748466)

[5.2.7.1 Design Rationale 15](#_Toc488748467)

[5.2.7.2 (Processing of function)……… 16](#_Toc488748468)

[5.2.8 FeNmiClkMonr3RtLowrLimFlt 16](#_Toc488748469)

[5.2.8.1 Design Rationale 16](#_Toc488748470)

[5.2.8.2 (Processing of function)……… 16](#_Toc488748471)

[5.2.9 FeNmiClkMonr3RtUpprLimFlt 16](#_Toc488748472)

[5.2.9.1 Design Rationale 16](#_Toc488748473)

[5.2.9.2 (Processing of function)……… 16](#_Toc488748474)

[5.2.10 FeNmiDmaTrf 16](#_Toc488748475)

[5.2.10.1 Design Rationale 16](#_Toc488748476)

[5.2.10.2 (Processing of function)……… 16](#_Toc488748477)

[5.2.11 FeNmiDmaRegAcsProtnErr 16](#_Toc488748478)

[5.2.11.1 Design Rationale 16](#_Toc488748479)

[5.2.11.2 (Processing of function)……… 16](#_Toc488748480)

[5.2.12 FeNmiEcmMstChkrCmp 16](#_Toc488748481)

[5.2.12.1 Design Rationale 16](#_Toc488748482)

[5.2.12.2 (Processing of function)……… 16](#_Toc488748483)

[5.2.13 FeNmiOperModErrFlsProgmModStrtd 17](#_Toc488748484)

[5.2.13.1 Design Rationale 17](#_Toc488748485)

[5.2.13.2 (Processing of function)……… 17](#_Toc488748486)

[5.2.14 FeNmiOperModErrSngChipInactv 17](#_Toc488748487)

[5.2.14.1 Design Rationale 17](#_Toc488748488)

[5.2.14.2 (Processing of function)……… 17](#_Toc488748489)

[5.2.15 FeNmiOperModErrTestModStrtd 17](#_Toc488748490)

[5.2.15.1 Design Rationale 17](#_Toc488748491)

[5.2.15.2 (Processing of function)……… 17](#_Toc488748492)

[5.2.16 FeNmiPeg 17](#_Toc488748493)

[5.2.16.1 Design Rationale 17](#_Toc488748494)

[5.2.16.2 (Processing of function)……… 17](#_Toc488748495)

[5.2.17 FeNmiWdg 17](#_Toc488748496)

[5.2.17.1 Design Rationale 17](#_Toc488748497)

[5.2.17.2 (Processing of function)……… 17](#_Toc488748498)

[5.2.18 GetMcuDiagcIdnData 18](#_Toc488748499)

[5.2.18.1 Design Rationale 18](#_Toc488748500)

[5.2.18.2 (Processing of function)……… 18](#_Toc488748501)

[5.2.19 ProcMpuExcpnErr 18](#_Toc488748502)

[5.2.19.1 Design Rationale 18](#_Toc488748503)

[5.2.19.2 (Processing of function)……… 18](#_Toc488748504)

[5.2.20 ProcNonCritOsErr 18](#_Toc488748505)

[5.2.20.1 Design Rationale 18](#_Toc488748506)

[5.2.20.2 (Processing of function)……… 18](#_Toc488748507)

[5.2.21 ProcPrmntOsErr 18](#_Toc488748508)

[5.2.21.1 Design Rationale 18](#_Toc488748509)

[5.2.21.2 (Processing of function)……… 18](#_Toc488748510)

[5.2.22 ProcPrvlgdInstrExcpnErr 18](#_Toc488748511)

[5.2.22.1 Design Rationale 18](#_Toc488748512)

[5.2.22.2 (Processing of function)……… 18](#_Toc488748513)

[5.2.23 ProcUkwnExcpnErr 19](#_Toc488748514)

[5.2.23.1 Design Rationale 19](#_Toc488748515)

[5.2.23.2 (Processing of function)……… 19](#_Toc488748516)

[5.2.24 SetMcuDiagcIdnData 19](#_Toc488748517)

[5.2.24.1 Design Rationale 19](#_Toc488748518)

[5.2.24.2 (Processing of function)……… 19](#_Toc488748519)

[5.3 Interrupt Functions 19](#_Toc488748520)

[5.3.1 AlgnErrIrq 19](#_Toc488748521)

[5.3.1.1 Design Rationale 19](#_Toc488748522)

[5.3.1.2 (Processing of the ISR function)….. 19](#_Toc488748523)

[5.3.2 FpuErrIrq 19](#_Toc488748524)

[5.3.2.1 Design Rationale 19](#_Toc488748525)

[5.3.2.2 (Processing of the ISR function)….. 19](#_Toc488748526)

[5.3.3 SysErrIrq 19](#_Toc488748527)

[5.3.3.1 Design Rationale 19](#_Toc488748528)

[5.3.3.2 (Processing of the ISR function)….. 19](#_Toc488748529)

[5.3.4 ResdOperIrq 20](#_Toc488748530)

[5.3.4.1 Design Rationale 20](#_Toc488748531)

[5.3.4.2 (Processing of the ISR function)….. 20](#_Toc488748532)

[5.4 Module Internal (Local) Functions 20](#_Toc488748533)

[5.4.1 ProcStrtUpOrSwRst 20](#_Toc488748534)

[5.4.1.1 Design Rationale 20](#_Toc488748535)

[5.4.1.2 Processing 20](#_Toc488748536)

[5.4.2 ProcPinRst 20](#_Toc488748540)

[5.4.2.1 Design Rationale 20](#_Toc488748541)

[5.4.2.2 Processing 20](#_Toc488748542)

[5.4.3 McuDiagcRstChk 20](#_Toc488748543)

[5.4.3.1 Design Rationale 21](#_Toc488748544)

[5.4.3.2 Processing 21](#_Toc488748545)

[5.5 GLOBAL Function/Macro Definitions 21](#_Toc488748546)

[5.5.1 GLOBAL Function #1 21](#_Toc488748547)

[5.5.1.1 Design Rationale 21](#_Toc488748548)

[5.5.1.2 processing 21](#_Toc488748549)

[6 Known Limitations with Design 22](#_Toc488748550)

[7 UNIT TEST CONSIDERATION 23](#_Toc488748551)

[Appendix A Abbreviations and Acronyms 24](#_Toc488748552)

[Appendix B Glossary 25](#_Toc488748553)

[Appendix C References 26](#_Toc488748554)

# Introduction

## Purpose

This document details the design in the FDD and also lists out any deviations which were made from the design for the implementation due to any constraints in development. ExcpnHndlg MDD describes the exception handling / reset cause determination for microcontroller diagnostics

# ExcpnHndlg & High-Level Description

Refer FDD

# Design details of software module

## Graphical representation of ExcpnHndlg

## Data Flow Diagram

![](data:image/png;base64,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)

### Component level DFD

**N/A**

### Function level DFD

**N/A**

# Constant Data Dictionary

## Program (fixed) Constants

### Embedded Constants

#### Local Constants

|  |  |  |  |
| --- | --- | --- | --- |
| Constant Name | Resolution | Units | Value |
| FPCFGININVAL\_CNT\_T\_U32 | 1 | Counts | 0x0000001CU |
| FPCFGREGID\_CNT\_S32 | 1 | Counts | 10 |
| FPCFGSELNID\_CNT\_S32 | 1 | Counts | 0 |
| FPUINVLDOPERSTSBIT\_CNT\_U32 | 1 | Counts | ((uint32)(0x00004000U)) |
| FPUDIVBYZEROSTSBIT\_CNT\_U32 | 1 | Counts | ((uint32)(0x00002000U)) |
| FPUOVFSTSBIT\_CNT\_U32 | 1 | Counts | ((uint32)(0x00001000U)) |
| MEMERRINFOREADWRBIT\_CNT\_U32 | 1 | Counts | ((uint32)(0x00000001U)) |
| CF1STERSTRADRPARMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x00000004U)) |
| CF1STERSTRDBLBITMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x00000002U)) |
| CF1STERSTRSNGBITMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x00000001U)) |
| PRPHLBUSDATAPARMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x10000000U)) |
| DTSDBLBITMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x80000000U)) |
| CODFLSSNGBITHARDFLT\_CNT\_U08 | 1 | Counts | 1U |
| CODFLSECCDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| CODFLSADRPAR\_CNT\_U08 | 1 | Counts | 4U |
| CODFLASHEXECENAREGFAILR\_CNT\_U08 | 1 | Counts | 8U |
| MEMBISTSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 1U |
| LCLRAMECCSNGBITHARDFLT\_CNT\_U08 | 1 | Counts | 1U |
| LCLRAMECCDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| INVLDRAMAREA\_CNT\_U08 | 1 | Counts | 4U |
| DTSDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| DTSSNGBITFLT\_CNT\_U08 | 1 | Counts | 4U |
| SPI0PRPHLRAMDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| SPI1PRPHLRAMDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| SPI2PRPHLRAMDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| SPI3PRPHLRAMDBLBIT\_CNT\_U08 | 1 | Counts | 2U |
| BISTCODECCFAILR\_CNT\_U08 | 1 | Counts | 1U |
| LOGLBISTSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 4U |
| BISTNOTCMPL\_CNT\_U08 | 1 | Counts | 16U |
| CPULOCKSTEPSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 32U |
| DMALOCKSTEPSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 64U |
| FACIRSTTRFERR\_CNT\_U08 | 1 | Counts | 128U |
| LOCKSTEPCOMP\_CNT\_U08 | 1 | Counts | 1U |
| SYSVCIE\_CNT\_U08 | 1 | Counts | 2U |
| RESDOPER\_CNT\_U08 | 1 | Counts | 4U |
| ALGNREAD\_CNT\_U08 | 1 | Counts | 8U |
| ALGNWR\_CNT\_U08 | 1 | Counts | 16U |
| INSTRFETCH\_CNT\_U08 | 1 | Counts | 32U |
| INTCNCTRESDAREA\_CNT\_U08 | 1 | Counts | 64U |
| INVLDMEMACS\_CNT\_U08 | 1 | Counts | 128U |
| CLKMONR0RTLOWRLIMFLT\_CNT\_U08 | 1 | Counts | 4U |
| CLKMONR0RTUPPRLIMFLT\_CNT\_U08 | 1 | Counts | 8U |
| CLKMONR2RTLOWRLIMFLT\_CNT\_U08 | 1 | Counts | 64U |
| CLKMONR2RTUPPRLIMFLT\_CNT\_U08 | 1 | Counts | 128U |
| OPERMODERRFLSPROGMMODSTRTD\_CNT\_U08 | 1 | Counts | 1U |
| OPERMODERRTESTMODSTRTD\_CNT\_U08 | 1 | Counts | 2U |
| OPERMODERRSNGCHIPINACTV\_CNT\_U08 | 1 | Counts | 4U |
| CLKMONR1RTLOWRLIMFLT\_CNT\_U08 | 1 | Counts | 4U |
| CLKMONR1RTUPPRLIMFLT\_CNT\_U08 | 1 | Counts | 8U |
| CLKMONR3RTLOWRLIMFLT\_CNT\_U08 | 1 | Counts | 64U |
| CLKMONR3RTUPPRLIMFLT\_CNT\_U08 | 1 | Counts | 128U |
| DATAANDINSTRPROTNERR\_CNT\_U08 | 1 | Counts | 1U |
| ECMSTSFLT\_CNT\_U08 | 1 | Counts | 1U |
| EIINTRPTSTRTUPFLT\_CNT\_U08 | 1 | Counts | 2U |
| ECMMSTSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 4U |
| ECMCHKRSTRTUPTESTFAILR\_CNT\_U08 | 1 | Counts | 8U |
| ECMPSDOERRINJFLT\_CNT\_U08 | 1 | Counts | 16U |
| ECMRTMSTCHKRCOMPFLT\_CNT\_U08 | 1 | Counts | 128U |
| FPUINVLDOPEREXCPN\_CNT\_U08 | 1 | Counts | 2U |
| FPUDIVBYZEROEXCPN\_CNT\_U08 | 1 | Counts | 4U |
| FPUOVFEXCPN\_CNT\_U08 | 1 | Counts | 8U |
| FPUUKWNEXCPN\_CNT\_U08 | 1 | Counts | 16U |
| UKWNRST\_CNT\_U08 | 1 | Counts | 1U |
| UKWNECMRST\_CNT\_U08 | 1 | Counts | 2U |
| BACKUPRAMTSTFAILRINBTLDR\_CNT\_U08 | 1 | Counts | 8U |
| UKWNSWRST\_CNT\_U08 | 1 | Counts | 16U |
| BACKUPRAMTSTFAILR\_CNT\_U08 | 1 | Counts | 32U |
| FLSBTLDRPREOSSRTUPEXCPN\_CNT\_U08 | 1 | Counts | 64U |
| STRTUPRSTINFOFAILD\_CNT\_U08 | 1 | Counts | 128U |
| PROGFLOW\_CNT\_U08 | 1 | Counts | 1U |
| DEADLINEMONR\_CNT\_U08 | 1 | Counts | 2U |
| ALVMONR\_CNT\_U08 | 1 | Counts | 4U |
| WDGTOUT\_CNT\_U08 | 1 | Counts | 1U |
| PEGRTFLT\_CNT\_U08 | 1 | Counts | 2U |
| IPGRTFLT\_CNT\_U08 | 1 | Counts | 8U |
| PBGSTRTUPTSTAILR\_CNT\_U08 | 1 | Counts | 16U |
| PBGRTFLT\_CNT\_U08 | 1 | Counts | 32U |
| DBGRST\_CNT\_U08 | 1 | Counts | 1U |
| OSCRITFLT\_CNT\_U08 | 1 | Counts | 1U |
| UKWNEXCPN\_CNT\_U08 | 1 | Counts | 2U |
| OSNONCRITFLT\_CNT\_U08 | 1 | Counts | 1U |
| DMATRFERR\_CNT\_U08 | 1 | Counts | 1U |
| DMAREGACSPROTCNERR\_CNT\_U08 | 1 | Counts | 2U |
| PRPHLBUSDATAPARSTRTUPFLT\_CNT\_U08 | 1 | Counts | 64U |
| PRPHLBUSDATAPARPRTFLT\_CNT\_U08 | 1 | Counts | 128U |
| INTCVMOVERVLTGMONR\_CNT\_U08 | 1 | Counts | 1U |
| INTCVMUNDERVLTGMONR\_CNT\_U08 | 1 | Counts | 2U |
| INTMONRLOVCCFLT\_CNT\_U08 | 1 | Counts | 16U |
| EXTVLTGMONRFLT\_CNT\_U08 | 1 | Counts | 128U |
| UPPR16BITMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0xFFFF0000U)) |
| LOWR16BITMASK\_CNT\_U32 | 1 | Counts | ((uint32)(0x0000FFFFU)) |
| INTCNCTRESDAREA1UPPRADR\_CNT\_U08 | 1 | Counts | (0XFFFF4FFFU) |
| INTCNCTRESDAREA1LOWRADR\_CNT\_U08 | 1 | Counts | (0xFFFF0000U) |
| INTCNCTRESDAREA2UPPRADR\_CNT\_U08 | 1 | Counts | (0XFFFEBFFFU) |
| INTCNCTRESDAREA2LOWRADR\_CNT\_U08 | 1 | Counts | (0xFFFE0000U) |
| INTCNCTRESDAREA3UPPRADR\_CNT\_U08 | 1 | Counts | (0XFE9FFFFFU) |
| INTCNCTRESDAREA3LOWRADR\_CNT\_U08 | 1 | Counts | (0XFB000000U) |
| INTCNCTRESDAREA4UPPRADR\_CNT\_U08 | 1 | Counts | (0XF8FFFFFFU) |
| INTCNCTRESDAREA4LOWRADR\_CNT\_U08 | 1 | Counts | (0XF3000000U) |
| INVLDMEMACSUPPRADR\_CNT\_U08 | 1 | Counts | (0XFFFF7EFFU) |
| INVLDMEMACSLOWRADR\_CNT\_U08 | 1 | Counts | (0xFFFF7900U) |
| FEPCREGID\_CNT\_S32 | 1 | Counts | 2 |
| FEPCSELNID\_CNT\_S32 | 1 | Counts | 0 |
| MEAREGID\_CNT\_S32 | 1 | Counts | 6 |
| MEASELNID\_CNT\_S32 | 1 | Counts | 2 |
| NROFBRAMDATREGS\_CNT\_U08 | 1 | Counts | ((uint8)4U) |
| SIZEOFBRAMDATREGS\_CNT\_U08 | 1 | Counts | ((uint8)4U) |

# Software Component Implementation

## Sub-Module Functions

## Init: ExcpnHndlgInit1

## Design Rationale

*Non-RTE function because it needs to be called before the OS is started - so that floating point exceptions can be enabled before anything uses floating point*

## Module Outputs

*None*

## Init: ExcpnHndlgInit2

## Design Rationale

*RTE function to initialize all the NTCs to pass*

## Module Outputs

*None*

## Per: ExcpnHndlgPer1

## Design Rationale

*RTE Periodic function called every 2 ms to check for OS errors*

## Store Module Inputs to Local copies

*Refer MDD*

## (Processing of function)………

*Triggered on Timing Event every 2ms*

## Store Local copy of outputs into Module Outputs

*None*

## Server Runables

## ChkForStrtUpTest

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr0RtLowrLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr0RtUpprLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr1RtLowrLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr1RtUpprLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr2RtLowrLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr2RtUpprLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr3RtLowrLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiClkMonr3RtUpprLimFlt

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiDmaTrf

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiDmaRegAcsProtnErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiEcmMstChkrCmp

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiOperModErrFlsProgmModStrtd

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiOperModErrSngChipInactv

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiOperModErrTestModStrtd

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiPeg

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiWdg

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## FeNmiDtsEccSngBitErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## GetMcuDiagcIdnData

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## ProcMpuExcpnErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## ProcNonCritOsErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## ProcPrmntOsErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## ProcPrvlgdInstrExcpnErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## ProcUkwnExcpnErr

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## SetMcuDiagcIdnData

## Design Rationale

*Refer FDD*

## (Processing of function)………

*Refer FDD*

## Interrupt Functions

## AlgnErrIrq

## Design Rationale

*Refer FDD*

## (Processing of the ISR function)…..

*Refer FDD*

## FpuErrIrq

## Design Rationale

*Refer FDD*

## (Processing of the ISR function)…..

*Refer FDD*

## SysErrIrq

## Design Rationale

*Refer FDD*

## (Processing of the ISR function)…..

*Refer FDD*

## ResdOperIrq

## Design Rationale

*Refer FDD*

## (Processing of the ISR function)…..

*Refer FDD*

## Module Internal (Local) Functions

## ProcStrtUpOrSwRst

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ProcStrtUpOrSwRst | Type | Min | Max |
| **Arguments Passed** | None |  |  |  |
|  |  |  |  |  |
| **Return Value** | NA |  |  |  |

## Design Rationale

*Refer FDD*

## Processing

## ProcPinRst

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | ProcPinRst | Type | Min | Max |
| **Arguments Passed** | None |  |  |  |
|  |  |  |  |  |
| **Return Value** | NA |  |  |  |

## Design Rationale

*Refer FDD*

## Processing

## McuDiagcRstChk

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | McuDiagcRstChk | Type | Min | Max |
| **Arguments Passed** | RstInfo\_Cnt\_T\_enum | McuDiagc1 | Refer FDD\* | Refer FDD\* |
|  |  |  |  |  |
| **Return Value** | McuDiagcRstChk\_Cnt\_T\_lgc | Boolean | FALSE | TRUE |

## Design Rationale

*Checks if the reset cause is power on/Flash Progamming /Hard Reset /Soft Reset.*

## Processing

Refer the FDD

## GLOBAL Function/Macro Definitions

<If these are numerous and defined in a separate source file then reference the source file only.>

## GLOBAL Function #1

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Function Name** | (Exact name used) | Type | Min | Max |
| **Arguments Passed** | (if none, write None) | <Refer MDD guidelines[1]> | <Refer MDD guidelines[1]> | <Refer MDD guidelines[1]> |
|  | (Insert more rows for additional passed arguments) |  |  |  |
| **Return Value** | (if no value returned, write N/A) |  |  |  |

## Design Rationale

## processing

(Place flowchart/design for local function)

# Known Limitations with Design

None

# UNIT TEST CONSIDERATION

None

Abbreviations and Acronyms

| **Abbreviation or Acronym** | **Description** |
| --- | --- |
|  |  |
|  |  |

Glossary

**Note**: Terms and definitions from the source “Nexteer Automotive” take precedence over all other definitions of the same term. Terms and definitions from the source “Nexteer Automotive” are formulated from multiple sources, including the following:

* ISO 9000
* ISO/IEC 12207
* ISO/IEC 15504
* Automotive SPICE® Process Reference Model (PRM)
* Automotive SPICE® Process Assessment Model (PAM)
* ISO/IEC 15288
* ISO 26262
* IEEE Standards
* SWEBOK
* PMBOK
* Existing Nexteer Automotive documentation

| **Term** | **Definition** | **Source** |
| --- | --- | --- |
| MDD | Module Design Document |  |
| DFD | Data Flow Diagram |  |

References

| **Ref. #** | **Title** | **Version** |
| --- | --- | --- |
| 1 | AUTOSAR Specification of Memory Mapping (Link:[AUTOSAR\_SWS\_MemoryMapping.pdf](http://www.autosar.org/download/R4.0/AUTOSAR_SWS_MemoryMapping.pdf)) | v1.3.0 R4.0 Rev 2 |
| 2 | MDD Guideline | 1.02 |
| 3 | [Software Naming Conventions.doc](http://misagweb01.nexteer.com/eRoomReq/Files/erooms8/NextGeneration/0_fc55f/Software%20Naming%20Conventions%2003x(In%20Work).doc) | 1.02 |
| 4 | [Software Design and Coding Standards.doc](http://eroom1.nexteer.com/eRoomReq/Files/erooms8/NextGeneration/0_1a67a9/Software%20Design%20and%20Coding%20Standards.doc) | 2.01 |
| 5 | FDD (CM101A\_ExcpnHndlg\_Design) | See Synergy Subproject version |